gdkwindow-x11: Don't set WM_TAKE_FOCUS if accept_focus is FALSE
authorJasper St. Pierre <jstpierre@mecheye.net>
Thu, 17 Oct 2013 02:17:16 +0000 (22:17 -0400)
committerJasper St. Pierre <jstpierre@mecheye.net>
Mon, 21 Oct 2013 17:43:14 +0000 (13:43 -0400)
Otherwise, we'll be in the "Globally Active" mode instead of the
"No Input" mode.

https://bugzilla.gnome.org/show_bug.cgi?id=710389

gdk/x11/gdkwindow-x11.c

index fd6fbdfb2f6953fa7dc10e144dafee1d8665fb26..6ee7a9602f827a48bd56f6d8fbf86ae44c8aecd3 100644 (file)
@@ -772,9 +772,11 @@ set_wm_protocols (GdkWindow *window)
   int n = 0;
   
   protocols[n++] = gdk_x11_get_xatom_by_name_for_display (display, "WM_DELETE_WINDOW");
-  protocols[n++] = gdk_x11_get_xatom_by_name_for_display (display, "WM_TAKE_FOCUS");
   protocols[n++] = gdk_x11_get_xatom_by_name_for_display (display, "_NET_WM_PING");
 
+  if (window->accept_focus)
+    protocols[n++] = gdk_x11_get_xatom_by_name_for_display (display, "WM_TAKE_FOCUS");
+
 #ifdef HAVE_XSYNC
   if (GDK_X11_DISPLAY (display)->use_sync)
     protocols[n++] = gdk_x11_get_xatom_by_name_for_display (display, "_NET_WM_SYNC_REQUEST");
@@ -3489,7 +3491,10 @@ gdk_x11_window_set_accept_focus (GdkWindow *window,
 
       if (!GDK_WINDOW_DESTROYED (window) &&
          WINDOW_IS_TOPLEVEL_OR_FOREIGN (window))
-       update_wm_hints (window, FALSE);
+        {
+          update_wm_hints (window, FALSE);
+          set_wm_protocols (window);
+        }
     }
 }